<template>
  <a-row :gutter="24">
    <a-col :md="24">
      <a-card :style="cardStyle" :bordered="false">
        <!-- 查询区域 -->
        <div class="table-page-search-wrapper">
          <!-- 搜索区域 -->
          <a-form layout="inline" @keyup.enter.native="searchQuery">
            <a-row :gutter="24">
              <a-col :md="6" :sm="24">
                <a-form-item label="客户编号" :labelCol="labelCol" :wrapperCol="wrapperCol">
                  <a-input placeholder="请输入客户编号查询" v-model="queryParam.number"></a-input>
                </a-form-item>
              </a-col>
              <a-col :md="6" :sm="24">
                <a-form-item label="名称" :labelCol="labelCol" :wrapperCol="wrapperCol">
                  <a-input placeholder="请输入名称查询" v-model="queryParam.supplier"></a-input>
                </a-form-item>
              </a-col>
              <a-col :md="6" :sm="24">
                <a-form-item label="手机号码" :labelCol="labelCol" :wrapperCol="wrapperCol">
                  <a-input placeholder="请输入手机号码查询" v-model="queryParam.telephone"></a-input>
                </a-form-item>
              </a-col>
              <a-col :md="6" :sm="24">
                <a-form-item label="联系电话" :labelCol="labelCol" :wrapperCol="wrapperCol">
                  <a-input placeholder="请输入联系电话查询" v-model="queryParam.phonenum"></a-input>
                </a-form-item>
              </a-col>
              <span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
                <a-col :md="6" :sm="24">
                  <a-button type="primary" @click="searchQuery">查询</a-button>
                  <a-button style="margin-left: 8px" @click="searchReset">重置</a-button>
                </a-col>
              </span>
            </a-row>
          </a-form>
        </div>
        <!-- 操作按钮区域 -->
        <div class="table-operator" style="margin-top: 5px">
          <a-button v-if="btnEnableList.indexOf(1)>-1" @click="handleAdd" type="primary" icon="plus">新增</a-button>
          <a-button v-if="btnEnableList.indexOf(1)>-1" @click="batchDel" icon="delete">删除</a-button>
          <a-button v-if="btnEnableList.indexOf(1)>-1" @click="batchSetStatus(true)" icon="check-square">启用</a-button>
          <a-button v-if="btnEnableList.indexOf(1)>-1" @click="batchSetStatus(false)" icon="close-square">禁用</a-button>
          <a-button v-if="btnEnableList.indexOf(1)>-1" @click="handleImportXls()" icon="import">导入</a-button>
          <a-button v-if="btnEnableList.indexOf(3)>-1" @click="handleExportXls('客户信息')" icon="download">导出</a-button>
        </div>
        <!-- table区域-begin -->
        <div>
          <a-table
            ref="table"
            size="middle"
            bordered
            rowKey="id"
            :columns="columns"
            :dataSource="dataSource"
            :pagination="ipagination"
            :scroll="scroll"
            :loading="loading"
            :rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}"
            @change="handleTableChange">
            <span slot="action" slot-scope="text, record">
              <a @click="handleEdit(record)">编辑</a>
              <a-divider v-if="btnEnableList.indexOf(1)>-1" type="vertical" />
              <a-popconfirm v-if="btnEnableList.indexOf(1)>-1" title="确定删除吗?" @confirm="() => handleDelete(record.id)">
                <a>删除</a>
              </a-popconfirm>
            </span>
            <!-- 状态渲染模板 -->
            <template slot="customRenderFlag" slot-scope="enabled">
              <a-tag v-if="enabled" color="green">启用</a-tag>
              <a-tag v-if="!enabled" color="orange">禁用</a-tag>
            </template>
          </a-table>
        </div>
        <!-- table区域-end -->
        <!-- 表单区域 -->
        <customer-modal ref="modalForm" @ok="modalFormOk"></customer-modal>
        <import-file-modal ref="modalImportForm" @ok="modalFormOk"></import-file-modal>
      </a-card>
    </a-col>
  </a-row>
</template>
<script>
import CustomerModal from './modules/CustomerModal'
import ImportFileModal from '@/components/tools/ImportFileModal'
import { JeecgListMixin } from '@/mixins/JeecgListMixin'
import JDate from '@/components/jeecg/JDate'
export default {
    name: 'CustomerList',
    mixins: [JeecgListMixin],
    components: {
        CustomerModal,
        ImportFileModal,
        JDate
    },
    data () {
        return {
            labelCol: {
                span: 5
            },
            wrapperCol: {
                span: 18,
                offset: 1
            },
            // 查询条件
            queryParam: {
                supplier: '',
                type: '客户',
                telephone: '',
                phonenum: ''
            },
            ipagination: {
                pageSizeOptions: ['10', '20', '30', '100', '200']
            },
            // 表头
            columns: [
                {
                    title: '#',
                    dataIndex: '',
                    key: 'rowIndex',
                    width: 60,
                    align: 'center',
                    customRender: function (t, r, index) {
                        return parseInt(index) + 1
                    }
                },
                {
                    title: '操作',
                    dataIndex: 'action',
                    width: 100,
                    align: 'center',
                    scopedSlots: { customRender: 'action' }
                },
                { title: '客户编号', dataIndex: 'number', width: 150, align: 'left' },
                { title: '名称', dataIndex: 'supplier', width: 150, align: 'left' },
                { title: '联系人', dataIndex: 'contacts', width: 70, align: 'left' },
                { title: '手机号码', dataIndex: 'telephone', width: 100, align: 'left' },
                { title: '联系电话', dataIndex: 'phoneNum', width: 100, align: 'left' },
                { title: '电子邮箱', dataIndex: 'email', width: 150, align: 'left' },
                { title: '地址', dataIndex: 'address', width: 150, align: 'left' },
                // { title: '期初应收', dataIndex: 'beginNeedGet', width: 80, align: 'left' },
                // { title: '期末应收', dataIndex: 'allNeedGet', width: 80, align: 'left' },
                { title: '税率(%)', dataIndex: 'taxRate', width: 80, align: 'left' },
                { title: '排序', dataIndex: 'sort', width: 60, align: 'left' },
                { title: '状态',
                    dataIndex: 'enabled',
                    width: 60,
                    align: 'center',
                    scopedSlots: { customRender: 'customRenderFlag' }
                }
            ],
            url: {
                list: '/supplier/list',
                delete: '/supplier/delete',
                deleteBatch: '/supplier/deleteBatch',
                importExcelUrl: '/supplier/importCustomer',
                exportXlsUrl: '/supplier/exportExcel',
                batchSetStatusUrl: '/supplier/batchSetStatus'
            }
        }
    },
    computed: {
        importExcelUrl: function () {
            return `${window._CONFIG['domianURL']}${this.url.importExcelUrl}`
        }
    },
    created () {
    },
    methods: {
        searchReset () {
            this.queryParam = {
                type: '客户'
            }
            this.loadData(1)
        },
        handleImportXls () {
            let importExcelUrl = this.url.importExcelUrl
            let templateUrl = '/doc/customer_template.xls'
            let templateName = '客户Excel模板[下载]'
            this.$refs.modalImportForm.initModal(importExcelUrl, templateUrl, templateName)
            this.$refs.modalImportForm.title = '客户导入'
        },
        handleEdit: function (record) {
            this.$refs.modalForm.edit(record)
            this.$refs.modalForm.title = '编辑'
            this.$refs.modalForm.disableSubmit = false
            if (this.btnEnableList.indexOf(1) === -1) {
                this.$refs.modalForm.isReadOnly = true
            }
        }
    }
}
</script>
<style scoped>
  @import '~@assets/less/common.less'
</style>
